home *** CD-ROM | disk | FTP | other *** search
/ Suzy B Software 2 / Suzy B Software CD-ROM 2 (1994).iso / prntutil / gs252b / atari / gdevprn.h < prev    next >
C/C++ Source or Header  |  1995-04-25  |  8KB  |  196 lines

  1. /* Copyright (C) 1989, 1992 Aladdin Enterprises.  All rights reserved.
  2.    Distributed by Free Software Foundation, Inc.
  3.  
  4. This file is part of Ghostscript.
  5.  
  6. Ghostscript is distributed in the hope that it will be useful, but
  7. WITHOUT ANY WARRANTY.  No author or distributor accepts responsibility
  8. to anyone for the consequences of using it or for whether it serves any
  9. particular purpose or works at all, unless he says so in writing.  Refer
  10. to the Ghostscript General Public License for full details.
  11.  
  12. Everyone is granted permission to copy, modify and redistribute
  13. Ghostscript, but only under the conditions described in the Ghostscript
  14. General Public License.  A copy of this license is supposed to have been
  15. given to you along with Ghostscript so you can know your rights and
  16. responsibilities.  It should be in a file named COPYING.  Among other
  17. things, the copyright notice and this notice must be preserved on all
  18. copies.  */
  19.  
  20. /* gdevprn.h */
  21. /* Common header file for memory-buffered printers */
  22.  
  23. #include "memory_.h"
  24. #include "string_.h"
  25. #include "gx.h"
  26. #include "gserrors.h"
  27. #include "gsmatrix.h"            /* for gxdevice.h */
  28. #include "gxdevice.h"
  29. #include "gxdevmem.h"
  30. #include "gxclist.h"
  31.  
  32. #ifdef atarist
  33. #  include "stprint.h"        /* header for fast centronics printing */
  34. #endif
  35.  
  36. /* Define the parameters for the printer rendering method. */
  37. /* If the entire bitmap fits in PRN_MAX_BITMAP, and there is at least */
  38. /* PRN_MIN_MEMORY_LEFT memory left after allocating it, render in RAM, */
  39. /* otherwise use a command list with a size of PRN_BUFFER_SPACE. */
  40. /* (These are "properties" that can be changed by a Ghostscript program.) */
  41. #if arch_ints_are_short
  42. /* 16-bit machines have little dinky RAMs.... */
  43. #  define PRN_MAX_BITMAP 32000
  44. #  define PRN_BUFFER_SPACE 25000
  45. #  define PRN_MIN_MEMORY_LEFT 32000
  46. #else
  47. #  ifdef atarist
  48. #    define PRN_MAX_BITMAP 10000000L
  49. #    define PRN_BUFFER_SPACE 100000L
  50. #    define PRN_MIN_MEMORY_LEFT 10000
  51. #  else
  52. /* 32-bit machines have great big hulking RAMs.... */
  53. #    define PRN_MAX_BITMAP 10000000L
  54. #    define PRN_BUFFER_SPACE 1000000L
  55. #    define PRN_MIN_MEMORY_LEFT 500000L
  56. #  endif
  57. #endif
  58. #define PRN_MIN_BUFFER_SPACE 10000    /* give up if less than this */
  59.  
  60. /* Define the declaration macro for print_page procedures. */
  61. #define dev_proc_print_page(proc)\
  62.   int proc(P2(gx_device_printer *, FILE *))
  63.  
  64. /* Structure for generic printer devices. */
  65. /* This must be preceded by gx_device_common. */
  66. /* Printer devices are actually a union of a memory device */
  67. /* and a clist device, plus some additional state. */
  68. #define gx_prn_device_common\
  69.     byte skip[max(sizeof(gx_device_memory), sizeof(gx_device_clist)) -\
  70.           sizeof(gx_device) + sizeof(double) /* padding */];\
  71.     /* The following is required only for devices where */\
  72.     /* output_page is gdev_prn_output_page; */\
  73.     /* it is ignored for other devices. */\
  74.     dev_proc_print_page((*print_page));\
  75.         /* ------ The following items must be set before ------ */\
  76.         /* ------ calling the device open routine. ------ */\
  77.     long max_bitmap;        /* max size of non-buffered bitmap */\
  78.     long use_buffer_space;        /* space to use for buffer */\
  79.     char fname[80];            /* output file name */\
  80.         /* ------ End of preset items ------ */\
  81.     FILE *file;            /* output file */\
  82.     char ccfname[30];        /* clist file name */\
  83.     FILE *ccfile;            /* command list scratch file */\
  84.     char cbfname[30];        /* clist block file name */\
  85.     FILE *cbfile;            /* command list block scratch file */\
  86.     long buffer_space;    /* amount of space for clist buffer, */\
  87.                     /* 0 means not using clist */\
  88.     byte *buf;            /* buffer for rendering */\
  89.     int page_count;            /* # of pages printed so far */\
  90.     gx_device_procs *orig_procs;    /* original procs */\
  91.     gx_device_procs mod_procs    /* modified procs */
  92.  
  93. /* The device descriptor */
  94. typedef struct gx_device_printer_s gx_device_printer;
  95. struct gx_device_printer_s {
  96.     gx_device_common;
  97.     gx_prn_device_common;
  98. };
  99.  
  100. /* Macro for casting gx_device argument */
  101. #define prn_dev ((gx_device_printer *)dev)
  102.  
  103. /* Standard device procedures for printers */
  104. dev_proc_open_device(gdev_prn_open);
  105. dev_proc_output_page(gdev_prn_output_page);
  106. dev_proc_close_device(gdev_prn_close);
  107. dev_proc_map_rgb_color(gdev_prn_map_rgb_color);
  108. dev_proc_map_color_rgb(gdev_prn_map_color_rgb);
  109. dev_proc_get_props(gdev_prn_get_props);
  110. dev_proc_put_props(gdev_prn_put_props);
  111.  
  112. /* Macro for generating procedure table */
  113. #define prn_procs(p_open, p_output_page, p_close)\
  114.   prn_matrix_procs(p_open, gx_default_get_initial_matrix, p_output_page, p_close)
  115. #define prn_matrix_procs(p_open,p_get_initial_matrix, p_output_page, p_close)\
  116.  prn_color_matrix_procs(p_open, p_get_initial_matrix, p_output_page, p_close,\
  117.              gdev_prn_map_rgb_color, gdev_prn_map_color_rgb)
  118. /* See gdev_prn_open for explanation of the NULLs below. */
  119. #define prn_color_procs(p_open, p_output_page, p_close, p_map_rgb_color, p_map_color_rgb)\
  120.   prn_color_matrix_procs(p_open, gx_default_get_initial_matrix, p_output_page, p_close, p_map_rgb_color, p_map_color_rgb)
  121. #define prn_color_matrix_procs(p_open, p_get_initial_matrix, p_output_page, p_close, p_map_rgb_color, p_map_color_rgb) {\
  122.     p_open,\
  123.     p_get_initial_matrix,\
  124.     gx_default_sync_output,\
  125.     p_output_page,\
  126.     p_close,\
  127.     p_map_rgb_color,\
  128.     p_map_color_rgb,\
  129.     NULL,    /* fill_rectangle */\
  130.     NULL,    /* tile_rectangle */\
  131.     NULL,    /* copy_mono */\
  132.     NULL,    /* copy_color */\
  133.     NULL,    /* draw_line */\
  134.     gx_default_get_bits,\
  135.     gdev_prn_get_props,\
  136.     gdev_prn_put_props\
  137. }
  138.  
  139. /* The standard printer device procedures */
  140. /* (using gdev_prn_open/output_page/close). */
  141. extern gx_device_procs prn_std_procs;
  142.  
  143. /* Macro for generating the device descriptor. */
  144. /*
  145.  * The computations of page width and height in pixels should really be
  146.  *    ((int)(page_width_inches*x_dpi))
  147.  * but some compilers (the Ultrix 3.X pcc compiler and the HPUX compiler)
  148.  * can't cast a computed float to an int.  That's why we specify
  149.  * the page width and height in inches/10 instead of inches.
  150.  *
  151.  * Note that the macro is broken up so as to be usable for devices that
  152.  * add further initialized state to the printer device.
  153.  */
  154. #define prn_device_body(devtype, procs, dev_name, width_10ths, height_10ths, x_dpi, y_dpi, l_margin, b_margin, r_margin, t_margin, num_comp, depth, max_gray, max_rgb, dither_gray, dither_rgb, print_page)\
  155.     sizeof(devtype),\
  156.     &procs,\
  157.     dev_name,\
  158.     (int)((long)width_10ths * x_dpi / 10),    /* width */\
  159.     (int)((long)height_10ths * y_dpi / 10),    /* height */\
  160.     x_dpi,\
  161.     y_dpi,\
  162.     l_margin, b_margin, r_margin, t_margin,\
  163.      { num_comp, depth, max_gray, max_rgb, dither_gray, dither_rgb },\
  164.     0,        /* not initialized yet */\
  165.       { 0 },    /* skip */\
  166.     print_page,\
  167.     PRN_MAX_BITMAP,\
  168.     PRN_BUFFER_SPACE,\
  169.       { 0 },    /* fname */\
  170.     0, { 0 }, 0, { 0 }, 0, 0, 0, 0, 0, { 0 }    /* ... mod_procs */
  171. #define prn_device(procs, dev_name, width_10ths, height_10ths, x_dpi, y_dpi, l_margin, b_margin, r_margin, t_margin, color_bits, print_page)\
  172. { prn_device_body(gx_device_printer, procs, dev_name,\
  173.     width_10ths, height_10ths, x_dpi, y_dpi,\
  174.     l_margin, b_margin, r_margin, t_margin,\
  175.     (color_bits > 1 ? 3 : 1),\
  176.     ((color_bits > 1) & (color_bits < 8) ? 8 : color_bits),\
  177.     (color_bits >= 8 ? 255 : 1),\
  178.     (color_bits >= 8 ? 255 : color_bits > 1 ? 1 : 0),\
  179.     (color_bits >= 8 ? 5 : 2),\
  180.     (color_bits >= 8 ? 5 : color_bits > 1 ? 2 : 0),\
  181.     print_page)\
  182. }
  183.  
  184. /* Common procedures defined in gdevprn.c */
  185. int gdev_prn_open_printer(P1(gx_device *));
  186. uint gdev_prn_raster(P1(gx_device_printer *));
  187. int gdev_prn_copy_scan_lines(P4(gx_device_printer *, int, byte *, uint));
  188. int gdev_prn_get_bits(P5(gx_device_printer *, int, byte *, uint, int));
  189. int gdev_prn_close_printer(P1(gx_device *));
  190.  
  191. /* BACKWARD COMPATIBILITY */
  192. #define gdev_mem_bytes_per_scan_line(dev)\
  193.   gdev_prn_raster((gx_device_printer *)(dev))
  194. #define gdev_prn_transpose_8x8(inp,ils,outp,ols)\
  195.   memflip8x8(inp,ils,outp,ols)
  196.